package com.example.crowdfunding.mvc.Controller;

import com.example.crowdfunding.constant.CrowdConstant;
import com.example.crowdfunding.entity.Menu;
import com.example.crowdfunding.service.api.MenuService;
import com.example.crowdfunding.utils.ResultEntity;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

import javax.annotation.Resource;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * The type Menu controller.
 */
@RestController
@RequestMapping(value = "/menu")
public class MenuController {

    @Resource
    private MenuService menuService;

    /**
     * Save menu result entity.
     *
     * @param menu the menu
     * @return the result entity
     */
    @RequestMapping("/save.json")
    public ResultEntity<String> saveMenu(Menu menu) {

        menuService.saveMenu(menu);
        return ResultEntity.successWithoutData(CrowdConstant.MESSAGE_SAVE_NODE_SUCCESS);
    }

    /**
     * Update menu result entity.
     *
     * @param menu the menu
     * @return the result entity
     */
    @RequestMapping("/update.json")
    public ResultEntity<String> updateMenu(Menu menu) {

        menuService.updateMenu(menu);
        return ResultEntity.successWithoutData(CrowdConstant.MESSAGE_UPDATE_NODE_SUCCESS);
    }

    /**
     * Remove menu result entity.
     *
     * @param id the id
     * @return the result entity
     */
    @RequestMapping("/remove.json")
    public ResultEntity<String> removeMenu(@RequestParam("id") Integer id) {

        menuService.removeMenu(id);
        return ResultEntity.successWithoutData(CrowdConstant.MESSAGE_DELETE_NODE_SUCCESS);
    }

    /**
     * Gets all tree.
     *
     * @return the all tree
     */
    @RequestMapping(value = "/get/tree.json")
    public ResultEntity<Menu> getAllTree() {

        // 1.查询全部的 Menu 对象
        List<Menu> menuList = menuService.getAll();

        // 2.声明一个变量用来存储找到的根节点
        Menu root = null;

        // 3.创建 Map 对象用来存储 id 和 Menu 对象的对应关系便于查找父节点
        Map<Integer, Menu> menuMap = new HashMap<>();

        // 4.遍历 menuList 填充 menuMap
        for (Menu menu : menuList) {
            Integer id = menu.getId();
            menuMap.put(id, menu);
        }

        // 5.再次遍历 menuList 查找根节点、组装父子节点
        for (Menu menu : menuList) {

            // 6.获取当前 menu 对象的 pid 属性值
            Integer pid = menu.getPid();

            // 7.如果 pid 为 null，判定为根节点
            if (pid == null) {
                root = menu;

                // 8.如果当前节点是根节点，那么肯定没有父节点，不必继续执行
                continue;
            }

            // 9.如果 pid 不为 null，说明当前节点有父节点，那么可以根据 pid 到 menuMap 中查找对应的 father 对象
            Menu father = menuMap.get(pid);

            // 10.将当前节点存入父节点的 children 集合
            father.getChildren().add(menu);
        }

        // 11.经过上面的运算，根节点包含了整个树形结构，返回根节点就是返回整个树
        return ResultEntity.successWithData(root, "成功返回完整的tree");
    }

}
